home *** CD-ROM | disk | FTP | other *** search
- #ifndef lint
- static char *RCSid = "$Id: eval.c,v 1.15 1998/03/22 22:31:30 drd Exp $";
- #endif
-
- /* GNUPLOT - eval.c */
-
- /*[
- * Copyright 1986 - 1993, 1998 Thomas Williams, Colin Kelley
- *
- * Permission to use, copy, and distribute this software and its
- * documentation for any purpose with or without fee is hereby granted,
- * provided that the above copyright notice appear in all copies and
- * that both that copyright notice and this permission notice appear
- * in supporting documentation.
- *
- * Permission to modify the software is granted, but not the right to
- * distribute the complete modified source code. Modifications are to
- * be distributed as patches to the released version. Permission to
- * distribute binaries produced by compiling modified sources is granted,
- * provided you
- * 1. distribute the corresponding source modifications from the
- * released version in the form of a patch file along with the binaries,
- * 2. add special version identification to distinguish your version
- * in addition to the base release version number,
- * 3. provide your name and address as the primary contact for the
- * support of your modified version, and
- * 4. retain our contact information in regard to use of the base
- * software.
- * Permission to distribute the released version of the source code along
- * with corresponding source modifications in the form of a patch file is
- * granted with same provisions 2 through 4 for binary distributions.
- *
- * This software is provided "as is" without express or implied warranty
- * to the extent permitted by applicable law.
- ]*/
-
-
- #include "plot.h"
-
-
- struct udvt_entry *
- add_udv(t_num) /* find or add value and return pointer */
- int t_num;
- {
- register struct udvt_entry **udv_ptr = &first_udv;
-
- /* check if it's already in the table... */
-
- while (*udv_ptr) {
- if (equals(t_num, (*udv_ptr)->udv_name))
- return (*udv_ptr);
- udv_ptr = &((*udv_ptr)->next_udv);
- }
-
- *udv_ptr = (struct udvt_entry *)
- gp_alloc((unsigned long) sizeof(struct udvt_entry), "value");
- (*udv_ptr)->next_udv = NULL;
- copy_str((*udv_ptr)->udv_name, t_num, MAX_ID_LEN);
- (*udv_ptr)->udv_value.type = INTGR; /* not necessary, but safe! */
- (*udv_ptr)->udv_undef = TRUE;
- return (*udv_ptr);
- }
-
-
- struct udft_entry *
- add_udf(t_num) /* find or add function and return pointer */
- int t_num; /* index to token[] */
- {
- register struct udft_entry **udf_ptr = &first_udf;
-
- int i;
- while (*udf_ptr) {
- if (equals(t_num, (*udf_ptr)->udf_name))
- return (*udf_ptr);
- udf_ptr = &((*udf_ptr)->next_udf);
- }
-
- /* get here => not found. udf_ptr points at first_udf or
- * next_udf field of last udf
- */
-
- if (standard(t_num))
- int_warn("Warning : udf shadowed by built-in function of the same name", t_num);
-
- /* create and return a new udf slot */
-
- *udf_ptr = (struct udft_entry *)
- gp_alloc((unsigned long) sizeof(struct udft_entry), "function");
- (*udf_ptr)->next_udf = (struct udft_entry *) NULL;
- (*udf_ptr)->definition = NULL;
- (*udf_ptr)->at = NULL;
- copy_str((*udf_ptr)->udf_name, t_num, MAX_ID_LEN);
- for (i = 0; i < MAX_NUM_VAR; i++)
- (void) Ginteger(&((*udf_ptr)->dummy_values[i]), 0);
- return (*udf_ptr);
- }
-
-
- int standard(t_num) /* return standard function index or 0 */
- int t_num;
- {
- register int i;
- for (i = (int) SF_START; ft[i].f_name != NULL; i++) {
- if (equals(t_num, ft[i].f_name))
- return (i);
- }
- return (0);
- }
-
-
-
- void execute_at(at_ptr)
- struct at_type *at_ptr;
- {
- register int i, index, count, offset;
-
- count = at_ptr->a_count;
- for (i = 0; i < count;) {
- index = (int) at_ptr->actions[i].index;
- offset = (*ft[index].func) (&(at_ptr->actions[i].arg));
- if (is_jump(index))
- i += offset;
- else
- i++;
- }
- }
-
- /*
-
- 'ft' is a table containing C functions within this program.
-
- An 'action_table' contains pointers to these functions and arguments to be
- passed to them.
-
- at_ptr is a pointer to the action table which must be executed (evaluated)
-
- so the iterated line exectues the function indexed by the at_ptr and
- passes the address of the argument which is pointed to by the arg_ptr
-
- */
-